import Vue from 'vue'
import Vuex from 'vuex'
// 1. 导入包
import createPersistedState from 'vuex-persistedstate'
import axios from 'axios'

Vue.use(Vuex)

export default new Vuex.Store({
  // 2. 配置为 vuex 的插件
  plugins: [createPersistedState()],
  state: {
    // 登录成功的token
    token: '',
    // 用户信息
    userInfo: null
  },
  mutations: {
    // 更新用户信息
    updateUserInfo (state, info) {
      state.userInfo = info
    },
    // 更新token信息
    updateToken (state, token) {
      state.token = token
    }
  },
  actions: {
    // 获取用户信息
    async getUserInfo (context) {
      const ret = await axios.get('/my/userinfo')
      if (ret.data.code === 0) {
        // 获取成功，更新状态
        context.commit('updateUserInfo', ret.data.data)
      }
    }
  },
  modules: {
  }
})
